অ্যাজাক্স (Ajax)

FormData Object এর ব্যবহার

Web Development - অ্যাজাক্স (Ajax) - Ajax এর মাধ্যমে File Upload (Uploading Files with Ajax) | NCTB BOOK

Ajax এ FormData অবজেক্ট ব্যবহার করে HTML ফর্ম ডেটা পাঠানো একটি আধুনিক এবং সহজ পদ্ধতি, যা ফর্ম ডেটা সংগ্রহ এবং প্রক্রিয়াকরণের কাজকে অনেক সহজ করে তোলে। এটি XMLHttpRequest এর মাধ্যমে ফর্ম ডেটা অ্যাসিনক্রোনাসভাবে (পেজ রিফ্রেশ ছাড়াই) সার্ভারে পাঠাতে ব্যবহৃত হয়। HTML5 এবং JavaScript এ FormData অবজেক্ট ব্যবহার করে ফাইল সহ বিভিন্ন ধরনের ইনপুট ডেটা সহজেই সার্ভারে পাঠানো যায়।

FormData অবজেক্ট কি?

FormData একটি জাভাস্ক্রিপ্ট অবজেক্ট, যা HTML ফর্মের ইনপুট ভ্যালুগুলো সংগ্রহ করে এবং একটি কী-ভ্যালু পেয়ার হিসাবে সংরক্ষণ করে। এটি ইনপুট টাইপের পার্থক্য না করে (যেমন টেক্সট ইনপুট, ফাইল ইনপুট) সব ধরনের ডেটা সহজেই সংগ্রহ এবং প্রক্রিয়া করতে পারে।

FormData অবজেক্টের সুবিধা:

  • সহজ এবং স্বয়ংক্রিয় ডেটা সংগ্রহ: একটি HTML ফর্মের সব ইনপুট ফিল্ডের ডেটা খুব সহজে সংগ্রহ করতে পারে।
  • ফাইল আপলোড সমর্থন: FormData অবজেক্ট ব্যবহার করে ফাইল ডেটা সার্ভারে পাঠানো যায়।
  • Ajax এর সাথে কাজ করা সহজ: Ajax (XMLHttpRequest বা fetch()) এর মাধ্যমে FormData খুব সহজেই পাঠানো যায়।
  • পেজ রিফ্রেশ ছাড়াই ফর্ম সাবমিশন: Ajax এর সাথে ব্যবহারের ফলে ফর্ম ডেটা পাঠানোর জন্য পেজ রিফ্রেশ করতে হয় না।

উদাহরণ: Ajax এবং FormData ব্যবহার করে ফর্ম ডেটা সাবমিট করা

১. HTML এবং JavaScript (index.html):

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>FormData Example</title>
</head>
<body>
    <h1>Employee Registration Form</h1>
    <form id="employeeForm">
        <label for="name">Name:</label>
        <input type="text" id="name" name="name" required>
        <br><br>
        <label for="email">Email:</label>
        <input type="email" id="email" name="email" required>
        <br><br>
        <label for="department">Department:</label>
        <input type="text" id="department" name="department" required>
        <br><br>
        <button type="button" onclick="submitForm()">Submit</button>
    </form>

    <div id="response-container">
        <!-- রেসপন্স বা ত্রুটি মেসেজ এখানে দেখানো হবে -->
    </div>

    <script>
        function submitForm() {
            // ফর্ম এলিমেন্ট সংগ্রহ করা
            var form = document.getElementById('employeeForm');
            
            // FormData অবজেক্ট তৈরি করা
            var formData = new FormData(form);

            // XMLHttpRequest অবজেক্ট তৈরি করা
            var xhr = new XMLHttpRequest();

            // POST রিকোয়েস্ট ওপেন করা
            xhr.open("POST", "submit_form.php", true);

            // রেসপন্স হ্যান্ডলিং সেট করা
            xhr.onreadystatechange = function() {
                if (xhr.readyState === 4) {
                    if (xhr.status === 200) {
                        document.getElementById("response-container").innerHTML = xhr.responseText;
                    } else {
                        document.getElementById("response-container").innerHTML = "Error submitting the form!";
                    }
                }
            };

            // ত্রুটি হ্যান্ডলিংয়ের জন্য onerror ইভেন্ট হ্যান্ডলার সেট করা
            xhr.onerror = function() {
                document.getElementById("response-container").innerHTML = "Network error occurred. Please try again.";
            };

            // রিকোয়েস্ট পাঠানো
            xhr.send(formData);
        }
    </script>
</body>
</html>

বিস্তারিত ব্যাখ্যা:

  • HTML ফাইলে একটি ফর্ম (<form>) তৈরি করা হয়েছে যেখানে নাম, ইমেইল, এবং ডিপার্টমেন্ট ইনপুট ফিল্ড রয়েছে।
  • "Submit" বোতামে ক্লিক করলে submitForm() ফাংশন কল হয়, যা FormData অবজেক্ট তৈরি করে এবং Ajax এর মাধ্যমে ফর্ম ডেটা সার্ভারে পাঠায়।
  • response-container নামে একটি <div> এলিমেন্ট রয়েছে, যেখানে PHP স্ক্রিপ্ট থেকে প্রাপ্ত রেসপন্স বা ত্রুটি মেসেজ দেখানো হবে।

২. PHP স্ক্রিপ্ট (submit_form.php):

<?php
// ফর্ম থেকে ডেটা সংগ্রহ করা
$name = trim($_POST['name']);
$email = trim($_POST['email']);
$department = trim($_POST['department']);

// ভ্যালিডেশন চেক করা
if (empty($name) || empty($email) || empty($department)) {
    echo "All fields are required.";
    exit();
}

if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
    echo "Invalid email format.";
    exit();
}

// ডাটাবেস কানেকশন সেটআপ (আপনার তথ্য অনুযায়ী পরিবর্তন করুন)
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "test_db";

$conn = new mysqli($servername, $username, $password, $dbname);

// কানেকশন চেক করা
if ($conn->connect_error) {
    echo "Database connection error. Please try again later.";
    exit();
}

// SQL কুয়েরি তৈরি করা
$stmt = $conn->prepare("INSERT INTO employees (name, email, department) VALUES (?, ?, ?)");
$stmt->bind_param("sss", $name, $email, $department);

if ($stmt->execute()) {
    echo "Employee data submitted successfully!";
} else {
    echo "Error submitting data. Please try again.";
}

// কানেকশন এবং স্টেটমেন্ট বন্ধ করা
$stmt->close();
$conn->close();
?>

বিস্তারিত ব্যাখ্যা:

  1. ডেটা সংগ্রহ:
    • PHP স্ক্রিপ্ট $_POST ব্যবহার করে ফর্ম ডেটা সংগ্রহ করছে এবং ভ্যালিডেট করছে।
  2. ডাটাবেস কানেকশন:
    • PHP স্ক্রিপ্টে ডাটাবেস কানেকশন সেটআপ করা হয়েছে এবং ডেটা ইনসার্ট করার জন্য SQL কুয়েরি ব্যবহার করা হয়েছে।
  3. রেসপন্স তৈরি:
    • যদি ডেটা সফলভাবে ইনসার্ট হয়, একটি সফল মেসেজ রিটার্ন করা হয়েছে।
    • যদি কোনো ত্রুটি ঘটে, উপযুক্ত ত্রুটি মেসেজ দেখানো হয়েছে।

FormData অবজেক্টের ব্যবহার:

  • new FormData(form):
    • FormData অবজেক্ট তৈরি করা হয়েছে এবং ফর্মের সমস্ত ইনপুট ভ্যালু সংগ্রহ করা হয়েছে।
    • এটি ফর্মের প্রতিটি ইনপুট এলিমেন্টের নাম (name অ্যাট্রিবিউট) এবং মান (value) সংগ্রহ করে।
  • Ajax (XMLHttpRequest) এর সাথে ব্যবহার:
    • xhr.send(formData) দিয়ে FormData অবজেক্ট সরাসরি সার্ভারে পাঠানো হয়েছে।

FormData এর সুবিধা:

  • সহজ ডেটা সংগ্রহ: ফর্মের সব ইনপুট এলিমেন্টের ডেটা স্বয়ংক্রিয়ভাবে সংগ্রহ করা হয়, আলাদা করে ইনপুটগুলি পেতে হয় না।
  • ফাইল আপলোড সাপোর্ট: FormData অবজেক্টের মাধ্যমে সহজেই ফাইল আপলোড করা যায়, যা Ajax এর মাধ্যমে সম্ভব।
  • Flexible এবং Dynamic: ফর্মে যদি নতুন ইনপুট ফিল্ড যোগ করা হয়, FormData অবজেক্ট স্বয়ংক্রিয়ভাবে সেগুলো সংগ্রহ করে এবং পাঠাতে পারে।

সারসংক্ষেপ:

  • Ajax এবং HTML5 Integration: FormData অবজেক্ট Ajax এর সাথে ব্যবহার করা হয়েছে, যা ফর্ম ডেটা পেজ রিফ্রেশ ছাড়াই সার্ভারে পাঠাতে সাহায্য করে।
  • সিম্পল এবং কার্যকর: FormData ব্যবহার করলে ইনপুট ফিল্ডের ডেটা সংগ্রহ এবং প্রক্রিয়াকরণ খুবই সহজ এবং কার্যকর হয়।
  • Error Management: PHP স্ক্রিপ্টে ডেটা ভ্যালিডেশন এবং ত্রুটি হ্যান্ডলিং করে ব্যবহারকারীকে সঠিক ফিডব্যাক প্রদান করা হয়েছে।

এই উদাহরণটি অনুসরণ করে FormData এবং Ajax ব্যবহার করে ফর্ম ডেটা প্রক্রিয়াকরণ সম্পর্কে একটি পরিষ্কার ধারণা পাওয়া যায়, যা ওয়েব অ্যাপ্লিকেশন ডেভেলপমেন্টে একটি গুরুত্বপূর্ণ দক্ষতা।

Promotion